package 排序算法;

import java.util.Arrays;

/**
 * Created by yazai
 * Date: 22:33 2021/8/20
 * Description:
 */
public class BubbleSort {
    public static void main(String[] args) {
        int[] arr = new int[]{2, 3, 5, 6, 1};
        bubbleSort(arr);
        System.out.println(Arrays.toString(arr));
    }

    /**
     * 设置一个标志，如果这一趟发生了交换，则为true，否则为false。明显如果有一趟没有发生交换，说明排序已经完成。
     *
     * @param arr
     */
    public static void bubbleSort(int[] arr) {
        boolean flag = true;
        while (flag) {
            flag = false;
            for (int i = 0; i < arr.length - 1; i++) {//最坏的情况交换多少趟
                for (int j = 0; j < arr.length - 1 - i; j++) {//要减i是因为i已经排序了i轮了
                    if (arr[j] > arr[j + 1]) {

                        int temp = arr[j];
                        arr[j] = arr[j + 1];
                        arr[j + 1] = temp;
                        flag = true;  //发生交换flag就为true。
                    }

                }
            }

        }
    }
}
